# Clocked Synchronous Sequential Circuits

In sequential circuits output values depend both on input values and on the state of the circuit.

The clocked synchronous sequential circuits are designed based on *finite state* machine model where the current state is stored in memory elements (flip-flops).

All flip-flops are triggered with the same **clock signal** (synchronized). Therefore the machine can change its state only during the active transition of the clock signal. Sequential circuits can be designed according to following two models.

# a) Mealy Model (George H. Mealy, computer scientist, USA)

In this model, outputs are determined by a function of current input values and current state.



#### Digital Circuits

#### b) Moore Model

Edward Forrest Moore (1925-2003) Mathematician, computer scientist, USA

In this model, the output depends only on current state.

Input values determine only the next state.

And the state determines the output.



Most of sequential circuits can be designed in both Mealy and Moore models.

# Analysis of clocked synchronous sequential circuits

Before we start to design sequential circuits we will see how to analyze a given sequential circuit.

Reminder: Implementation of a sequential circuit means implementation of the functions F (next state) and G (output). (See 7.1 and 7.2)

I: Input, S: Current State, S+: Next state, O: Output  $S^+ = \mathbf{F}(I,S)$ , Mealy:  $O = \mathbf{G}(I,S)$  Moore:  $O = \mathbf{G}(S)$ 

Analysis of a synchronous circuits means, to find out the behavior of a circuit, which is given by the functions F and G. (What does the circuit do?)

Analysis of a synchronous circuits has 3 steps:

- 1. Determine the expressions of the functions F (next state) and G (output).
- 2. Use F and G functions to construct the state/output table that specifies the next state and output of the circuit for every possible combination of input and current state.
- 3. To see the behavior of the circuit better the state diagram can be optionally drawn, which shows all state transitions and outputs of the machine graphically.

http://www.faculty.itu.edu.tr/buzluca

© 2011-2013 Dr. Feza BUZLUCA

7.3

Digital Circuits

#### Determination of next states:

Characteristic Equations of flip-flops

F function of a clocked sequential circuit determines input values of flip-flops (flip-flop excitation).

These input values with the current state of the flip-flop determine its next state (output of the flip-flop after the transition of the clock signal).

The functional behavior of a latch or flip-flop can be described by a **characteristic equation** that specifies the flip-flop's next state as a function of its inputs and current.

Characteristic equations of flip-flops:

SR FF:  $Q(t+1) = S + R' \cdot Q(t)$ , SR=0

 $JK FF: Q(t+1) = J\bullet Q(t)' + K'\bullet Q(t)$ 

D FF: Q(t+1) = D

T FF:  $Q(t+1) = T \oplus Q(t)$ 

http://www.faculty.itu.edu.tr/buzluca

© 2011-2013 Dr. Feza BUZLUCA

7.4







- 4. Determining the expression of the output function G.  $Z = Q1 \cdot Q0 \cdot X$ (Mealy model, because output depends both on input and state)
- 5. Constructing the State/Output table



This table presents the behavior of the finite state machine.

This behavior can be also presented by a state diagram graphically.

State Diagram

Z=0



X=0

# Reading the table:

When the machine is in state A, if it gets 1 from the input, the output becomes 0; after the transition of the clock signal machine goes to state B.

Verbal expression of the behavior of the circuit: We assume that A is the initial state. Only if the number of 1s received from the input is a multiple of 4 then the output is 1. Otherwise the output is 0.

http://www.faculty.itu.edu.tr/buzluca ittp://www.buzluca.info

© 2011-2013 Dr. Feza BUZLUCA

7.7



## Example: Analysis of a clocked synchronous circuit with JK Flip-flops

Differently from the previous example, during determining the expressions of next states  $(Q_i^+)$ , here we will use the characteristic function of the JK flip-flop.



1. Determining the F function that drives the inputs of the flip-flops:

$$J0 = X \bullet Y' - X \bullet Q' + Y \bullet Q' - X \bullet Q$$

$$J1 = X \bullet Q0 + Y$$

$$K1 = Y \cdot Q0' + \cancel{X} \cdot Y' \cdot Q0$$

2. Next state  $S_{t} = \{Q_0(t^+), Q_1(t^+)\}$  expressions.

Q0+ = 
$$J0_{\bullet}Q0' + K0' \cdot Q0$$
 (JK FF characteristic function)

$$Q0^+ = X \cdot Y' \cdot Q0' + (X \cdot Y' + Y \cdot Q1)' \cdot Q0$$

$$Q0^{+} = X \cdot Y' \cdot Q0' + X' \cdot Y' \cdot Q0 + X' \cdot Q1' \cdot Q0 + Y \cdot Q1' \cdot Q0$$

$$Q0^{+} = X \bullet Y' \bullet Q0' + X' \bullet Y' \bullet Q0 + Y \bullet Q1' \bullet Q0$$
 (minimization)

$$Q1^+ = J1 \cdot Q1' + K1' \cdot Q1$$
 (JK FF characteristic function)

$$Q1^+ = (X \cdot Q0 + Y) \cdot Q1' + (Y \cdot Q0' + X \cdot Y' \cdot Q0)' \cdot Q1$$

$$Q1^+ = X \cdot Q1' \cdot Q0 + Y \cdot Q1' + X' \cdot Y' \cdot Q1 + Y' \cdot Q1 \cdot Q0' + X' \cdot Q1 \cdot Q0 + Y \cdot Q1 \cdot Q0$$

$$Q1^+ = X \cdot Q1' \cdot Q0 + Y \cdot Q1' + Y \cdot Q0 + X' \cdot Q1 \cdot Q0 + Y' \cdot Q1 \cdot Q0'$$
 (minimization)

3. Determining the expression of the output function G.

$$Z = X \cdot Q1 \cdot Q0 + Y \cdot Q1' \cdot Q0'$$

http://www.faculty.itu.edu.tr/buzluca

© 2011-2013 Dr. Feza BUZLUCA

7.9

#### Digital Circuits

## State/Output Table:

Q1+ Q0+ ,Z

|      |    | XY   |      |      |      |  |
|------|----|------|------|------|------|--|
| Q1Q0 |    | 00   | 01   | 10   | 11   |  |
|      | 00 | 0,00 | 10,1 | 01,0 | 10,1 |  |
|      | 01 | 01,0 | 11,0 | 10,0 | 11,0 |  |
|      | 10 | 10,0 | 00,0 | 11,0 | 00,0 |  |
|      | 11 | 11,0 | 10,0 | 00,1 | 10,1 |  |

# S+ ,Z\_

|   | XY  |            |     |     |  |  |
|---|-----|------------|-----|-----|--|--|
| S | 00  | 01         | 10  | 11  |  |  |
| Α | A,0 | C,1<br>D,0 | B,0 | C,1 |  |  |
| В | B,0 | D,0        | C,0 | D,0 |  |  |
| С | C,0 | A,0        | D,0 | A,0 |  |  |
| D | D,0 | C,0        | A,1 | C,1 |  |  |

## State Transition Diagram:



http://www.faculty.itu.edu.tr/buzluca http://www.buzluca.info

© 2011-2013 Dr. Feza BUZLUCA



Analysis of circuits designed with Moore model is very similar to Mealy model. Only construction and interpretation of the state/output table are different.

1. Determining the expression of F function that drives the flip-flops:

$$D0 = Q0 \cdot X' + Q0' \cdot X$$
  
 $D1 = Q1 \cdot X' + Q1' \cdot Q0 \cdot X + Q1 \cdot Q0' \cdot X$ 

2. Next state  $S^+=\{Q0(t^+), Q1(t^+)\}$  expressions.

$$Q0^+ = D0$$
  
 $Q1^+ = D1$ 

$$Q0^+ = Q0\bullet X' + Q0'\bullet X$$

$$Q1^{+} = Q1 \cdot X' + Q1' \cdot Q0 \cdot X + Q1 \cdot Q0' \cdot X$$

3. Transition table and state table are constructed.

| Q1+ | Q0+<br>X<br>01Q0     | 0                    | 1                    |                                                                | S <sup>+</sup> X |
|-----|----------------------|----------------------|----------------------|----------------------------------------------------------------|------------------|
|     | 00<br>01<br>10<br>11 | 00<br>01<br>10<br>11 | 01<br>10<br>11<br>00 | For simplicity alphanumeric names are assigned to state codes. | A<br>B<br>C<br>D |

0

A B C C D D A

- 4. Determining the expression of the output function G  $Z = Q1 \cdot Q0$  (Moore model; output depends only on state variables.)
- 5. Constructing the State/Output table



Since in Moore model output depends only on state, only one output value is written in each row, independently from inputs.

Each row corresponds to a state.





(Compare to diagram in 7.7)

http://www.faculty.itu.edu.tr/buzluca

© 2011-2013 Dr. Feza BUZLUCA

7.13

Digital Circuits

# Interpretation of Outputs in Mealy and Moore Models

If you check the output of a digital circuit at a certain moment you will always read a logical value 0 or 1 (except high impedance outputs).

But this value may not be valid due to some reasons for example due to internal delays. (The circuit has not finished its job yet.)

Therefore it is important when to read (sample) an output.

In clocked synchronous sequential circuits outputs are sampled (read) in different times dependent on the model (Mealy or Moore).

## Mealy Model:

Since the output depends also on input, if the input changes the output also changes at the same time (actually after the propagation delay).

Working steps of a circuit in Mealy model:

- 1. Input values (I) are given.
- 2. Output values are obtained as a function of input and current state. O=G(S,I)
- 3. Clock signal gets active. For example positive edge (0 to 1 transition).
- 4. The machine goes to the next state. Next state is a function of input and current state.  $S^+=F(S,I)$



## Moore Model:

Since the output is the function of the state only, in Moore model change in the input cannot affect the output immediately.

The effect of changes in input can be seen on the output just after the change in the state.

Working steps of a circuit in Moore model:

- 1. Input values (I) are given.
- 2. Clock signal gets active. For example positive edge (0 to 1 transition).
- 3. The machine goes to the next state. Next state is a function of input and current state.  $S^+=F(S,I)$
- 4. Output value is determined as a function of the new state. O=G(S)

In Moore model, effect of changes in inputs are seen after one clock pulse.





